<template>
    <el-dialog v-model="visible" :title="form.id ? $t('common.editBtn') : $t('common.addBtn')" width="600">
        <el-form
            ref="dataFormRef"
            :model="form"
            :rules="dataRules"
            formDialogRef
            label-width="90px"
            v-loading="loading"
        >
            <el-form-item :label="t('group.groupName')" prop="groupName">
                <el-input v-model="form.groupName" :placeholder="t('group.inputGroupNameTip')" />
            </el-form-item>
            <el-form-item :label="$t('group.templateType')" prop="templateId">
                <el-select
                    v-model="form.templateId"
                    :placeholder="$t('group.selectType')"
                    class="w100"
                    clearable
                    multiple
                >
                    <el-option
                        v-for="item in templateData"
                        :key="item.id"
                        :label="item.templateName"
                        :value="item.id"
                    />
                </el-select>
            </el-form-item>
            <el-form-item :label="t('group.groupDesc')" prop="groupDesc">
                <el-input
                    type="textarea"
                    maxlength="150"
                    rows="3"
                    v-model="form.groupDesc"
                    :placeholder="t('group.inputGroupDescTip')"
                />
            </el-form-item>
        </el-form>
        <template #footer>
            <span class="dialog-footer">
                <el-button @click="visible = false">{{ $t('common.cancelButtonText') }}</el-button>
                <el-button type="primary" @click="onSubmit" :disabled="loading">{{
                    $t('common.confirmButtonText')
                }}</el-button>
            </span>
        </template>
    </el-dialog>
</template>

<script lang="ts" name="GenGroupDialog" setup>
    import { useMessage } from '@/hooks/message'
    import { addObj, getObj, putObj } from '@/api/gen/group'
    import { useI18n } from 'vue-i18n'
    import { list as templateList } from '@/api/gen/template'
    // 定义子组件向父组件传值/事件
    const emit = defineEmits(['refresh'])
    const { t } = useI18n()

    // 定义变量内容
    const dataFormRef = ref()
    const visible = ref(false)
    const loading = ref(false)
    const templateData = ref<any[]>([])
    // 定义字典

    // 提交表单数据
    const form = reactive({
        id: '',
        groupName: '',
        groupDesc: '',
        templateId: [] as string[],
        putList: []
    })

    // 定义校验规则
    const dataRules = ref({
        groupName: [{ required: true, message: '分组名称不能为空', trigger: 'blur' }],
        templateId: [{ required: true, message: '模板不能为空', trigger: 'blur' }]
    })

    const openDialog = (id: string) => {
        visible.value = true
        form.id = ''

        // 重置表单数据
        nextTick(() => {
            dataFormRef.value.resetFields()
        })

        // 如果有 id 参数，获取 genGroup 信息
        if (id) {
            form.id = id
            getgenGroupData(id)
        }

        // 获取模板信息
        getTemplateData()
    }

    // 提交
    const onSubmit = async () => {
        const valid = await dataFormRef.value.validate().catch(() => {})
        if (!valid) return false

        try {
            loading.value = true
            form.id ? await putObj(form) : await addObj(form)
            useMessage().success(t(form.id ? 'common.editSuccessText' : 'common.addSuccessText'))
            visible.value = false
            emit('refresh')
        } catch (err: any) {
            useMessage().error(err.msg)
        } finally {
            loading.value = false
        }
    }

    // 初始化表单数据
    const getgenGroupData = (id: string) => {
        // 获取数据
        getObj(id).then((res: any) => {
            Object.assign(form, res.data)
            form.templateId = []
            if (res.data.templateList) {
                let list = res.data.templateList
                list.forEach(item => {
                    form.templateId.push(item.id)
                })
            }
        })
    }

    // 角色数据
    const getTemplateData = () => {
        templateList().then(res => {
            templateData.value = res.data
        })
    }

    // 暴露变量
    defineExpose({
        openDialog
    })
</script>
